table of contents
        
      
      
    | std::valarray::operator[](3) | C++ Standard Libary | std::valarray::operator[](3) | 
NAME¶
std::valarray::operator[] - std::valarray::operator[]
Synopsis¶
 T operator[]( std::size_t pos ) const; (until C++11)
  
   const T& operator[]( std::size_t pos ) const; (since C++11)
  
   T& operator[]( std::size_t pos ); (2)
  
   std::valarray<T> operator[]( std::slice slicearr ) const; (3)
  
   std::slice_array<T> operator[]( std::slice slicearr ); (4)
  
   std::valarray<T> operator[]( const std::gslice& gslicearr )
    (5)
  
   const;
  
   std::gslice_array<T> operator[]( const std::gslice& gslicearr
    (6)
  
   ); (1)
  
   std::valarray<T> operator[]( const valarray<bool>& boolarr )
    (7)
  
   const;
  
   std::mask_array<T> operator[]( const valarray<bool>& boolarr
    (8)
  
   );
  
   std::valarray<T> operator[]( const valarray<std::size_t>&
    (9)
  
   indarr ) const;
  
   std::indirect_array<T> operator[]( const (10)
  
   valarray<std::size_t>& indarr );
  
   Retrieve single elements or portions of the array.
  
   The const overloads that return element sequences create a new std::valarray
    object.
  
   The non-const overloads return classes holding references to the array
    elements.
Parameters¶
 pos - position of the element to return
  
   slicearr - slice of the elements to return
  
   gslicearr - gslice of the elements to return
  
   boolarr - mask of the elements to return
  
   indarr - indices of the elements to return
Return value¶
 1,2) A reference to the corresponding element
  
   3,5,7,9) A std::valarray object containing copies of the selected items
  
   4,6,8,10) The corresponding data structure containing references to the
    selected
  
   items
Exceptions¶
May throw implementation-defined exceptions.
Precondition¶
The selected elements must exist.
Notes¶
* For proper values of i and j, the following properties are true:
  
   1) (a[i] = q, a[i]) == q
  
   For a non-const a.
  
   2) &a[i+j] == &a[i] + j
  
   This means that valarray elements are adjacent in memory.
  
   3) &a[i] != &b[j]
  
   This holds for every objects a and b that are not aliases of one another.
  
   This means that there are no aliases in the elements and this property can
  
   be used to perform some kinds of optimization.
  
   * References become invalid on resize or when the array is destructed.
  
   For overloads (3,5,7,9), The function can be implemented with the return type
  
   different from std::valarray. In this case, the replacement type has the
    following
  
   properties:
  
   * All const member functions of std::valarray are provided.
  
   * std::valarray, std::slice_array, std::gslice_array, std::mask_array and
  
   std::indirect_array can be constructed from the replacement type.
  
   * All functions accepting an argument of type const std::valarray&
  
   except begin() and end()
  
   (since C++11) should also accept the replacement type.
  
   * All functions accepting two arguments of type const std::valarray&
  
   should accept every combination of const std::valarray& and the
  
   replacement type.
  
   * The return type does not add more than two levels of template nesting
  
   over the most deeply-nested argument type.
  
   Slice/mask/indirect index accesses do not chain: v[v==n][std::slice(0,5,2)] =
    x; is
  
   an error because std::mask_array (the type of v[v==n]) does not have
    operator[].
Example¶
// Run this code
  
   #include <iostream>
  
   #include <valarray>
  
   int main()
  
   {
  
   std::valarray<int> data = {0,1,2,3,4,5,6,7,8,9};
  
   std::cout << "Initial valarray: ";
  
   for(int n: data) std::cout << n << ' ';
  
   std::cout << '\n';
  
   data[data > 5] = -1; // valarray<bool> overload of operator[]
  
   // the type of data>5 is std::valarray<bool>
  
   // the type of data[data>5] is std::mask_array<int>
  
   std::cout << "After v[v>5]=-1: ";
  
   for(std::size_t n = 0; n < data.size(); ++n)
  
   std::cout << data[n] << ' '; // regular operator[]
  
   std::cout << '\n';
  
   }
Output:¶
 Initial valarray: 0 1 2 3 4 5 6 7 8 9
  
   After v[v>5]=-1: 0 1 2 3 4 5 -1 -1 -1 -1
| 2022.07.31 | http://cppreference.com |